<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <div id="app">
        <button @click="list.splice(1,0,{id:4,name:'老六'})">添加</button>
        <ul>
            <li v-for="item in list" :key="item.id">
                <input type="checkbox">
                <span>{{ item.name }}</span>
            </li>
        </ul>
    </div>
    <!-- 
        现象：当我勾了李四，然后在下标1的位置添加了老六，结果发现勾给了老六，李四自己没勾了。
        原因：v-for会尝试最大限度的复用当前元素，导致状态绑定错乱。
        解决：在v-for后加上一个key属性，key绑定这个数据的唯一值(一般是id，不能是字符串和数字类型)。 
    -->

    <script src="../../js/vue.js"></script>
    <script>
        new Vue({
            el:'#app',
            data:{
                list:[
                    {id:1,name:'张三'},
                    {id:2,name:'李四'},
                    {id:3,name:'王五'},
                ]
            }
        })
    </script>
</body>
</html>